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F. Les operateurs & fonctions de base 

1. Operateurs grithmetigues 


Definition 


■ Comme on I’a deja vu, I’affectation est effectuee par I'operateur := 

■ Les operateurs arithmetiques +-*et / ont les merries fonctions qu'ils ont dans les 
autres langages de programmation, sauf pour I'operateur ** qui signifie I'exposant : 

A ** B <=> A B 


Exemp/e 


DECLARE 

x NUMBER := 4; 
y NUMBER; 

BEGIN 

y := (x + 1) * 2; 

dbms_output .put_line ( 'produit : ’ | | y) ; 

y := (x + 1) ** 2; 

dbms_output .put_line ( ’puissance : ’ | | y) ; 

END ; 


Message 


DBMS Output 


produit: 10 

puissance: 25 


2. Fonctions grithmetigues 


Definition 


ABS(n) 

La valeur absolue de n 

CEIL (n) 

L'entier le plus petit qui soit superieur ou egal a n 

FLOOR (n) 

L’entier le plus grand qui soit inferieur ou egal a n 

GREATEST (nl , n2 , n3 ) 

La valeur la plus grande entre nl , n2 et n3 

LEAST (nl,n2,n3) 

La valeur la plus petite entre nl , n2 et n3 

REMAINDER (n,m) 

Le reste de la division euclidienne de n par m ( modulo ) 

POWER (n,m) 

n puissance m 

SQRT (n) 

La racine carree de n (square roof ) 


Exemple 


DECLARE 

x NUMBER; 
y NUMBER; 
z NUMBER; 
r NUMBER (3) ; 
rl NUMBER (2,1); 

BEGIN 

x := 1; 
y := 2; 
z := 3; 

r := "SQRT" ( (x + y) ** y); 

dbms_output .put_line ( ' resultat 1: ' | | r) ; 

r := "POWER" (r, "POWER" (y, y)); 
dbms_output .put_line (' resultat 2: ' | | r) ; 

r := "REMAINDER" (r + 1, "GREATEST" (x, y, z) ) ; 
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dbms output .put_line (' resul tat 3: ' | | r) ; 

rl := z / y; 

dbms output. put line (' resul tat 4: ’ll "FLOOR" (rl) ) ; 
dbms output. put line (' resul tat 5: ’ll "CEIL" (rl) ) ; 

END ; 




Message 

DBMS Output 


resultat 1: 3 
re suit at 2:: SI 
resultat 3: 1 
resultat 4:: 1 
resultat 5: 2 


3. Maniguler des dates 

a. Conversion date -> chaine avec formatage 


Definition : Fonction to char 


Cette fonction predefinie en PL/SQL permet de convertir une date en une chaine de 
caracteres, avec optionnellement un format de sortie, specifie en 2ieme parametre. 
(Les fonctions seront revues en detail dans les prochains paragraphes ) 

Syntaxe : 

"TO CHAR" (uneDate, 'unFormat'); 


Formats de sortie : 

Annee en 4 chiffres : yyyy 

Annee en 2 chiffres : yy 

Mois en chiffres : mm 

Mois en lettres : month 

Jour en chiffres : dd 

Jour en lettres : day 

Heures en format 12h : hh 

Heures en format 24h : HH24 

Minutes : mi 


Exemple 


DECLARE 

d DATE; 


v VARCHAR2 (50) ; 

BEGIN 

d := SYSDATE ; 
dbms_output . put_line (d) ; 

v := "TO CHAR" (d, 'DAY DD MONTH YYYY ' ) ; 

dbms_output . put_line ( v) ; 
v := "TO_CHAR"(d, 'DD-MONTH'); 
dbms_output . put_line ( v) ; 
v := "TO_CHAR"(d, 'DD/MM/YY HH24:MI'); 
dbms_output . put_line ( v) ; 

END ; 
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Message 

DBMS Output 


03 -MAR-1 5 

TUESDAY 03 MARCH 2015 
03 -MARCH 
03/03/1 5 16:15 


A IMPORTANT 

Le format par defaut d'une date est dd-mon-yy. 

Une declaration de variable de type date qui ne respecte pas cette specification 
conduit a une erreur d’execution. 


Exemple 


DECLARE 

d DATE; 

BEGIN 

d := ’22-01-2010’ ; 
dbms_output . put_line (d) 

END ; 


Message 


[SQL] DECLARE 
d DATE; 

BEGIN 

d := ' 22 - 01 - 2010 '; 
dbms_output.put_line(d); 

ENQ; 

[Err] ORAJD1843: not a valid monfFT 
LRA£6512: at line 4 


b. Fonctions sur les dates 


Definition 

ADD_MONTHS (date , n) 

Retourne la date + n mois, n peut etre positif ou negatif. 

DBTIMEZONE ( ) 

Retourne le fuseau horaire actuel (Ex. : +00:00, -01:00, ...) 

SYSDATE ( ) ou 
CURRENT_DATE ( ) 

Retourne la date actuelle. 

NEXT DAY (date , jour) 

Retourne le prochain jour de la semaine, qui correspond au 
jour specifie en 2'® me parametre, a partir de la date specifiee 
en l ier parametre. 

MONTHS_BETWEEN (da tel , 
date2 ) 

Retourne le nombre de mois entre datel et date2. 
(datel - date2) 


Exemple 


DECLARE 

dl DATE; 
d2 DATE; 

BEGIN 

dl := ' 01-JAN-2001 ' ; 
d2 := "ADD_MONTHS" (dl, 12); 
dbms_output . put_line (d2 ) ; 
d2 := "ADD_MONTHS" (dl, -2) ; 

dbms_output . put_line ( " TO_CHAR" (d2 , ' DD/MM/YYYY ' ) ) ; 
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dl := "CURRENT_DATE" () ; 

dbms__output .put_line ( ’ date courante: ’ ||dl); 

dbms_output .put_line ( ’ zone horaie: ’ || "DBTIMEZONE" () ) ; 

d2 := ’ 23-FEB-2015 ’ ; 

dbms_ou tpu t . put_line ( "TO_CHAR" (d2 , ’ DAY DD-MM-YYYY ' ) ) ; 

d2 : = "NEXT_DAY" (d2 , ' SUNDAY ' ) ; 

dbms_ou tpu t . put_line ( "TO_CHAR" (d2 , ’ DD-MONTH ' ) ) ; 

dl := ’ 01 -AUG-2 015 ’ ; 

dbms_ou tpu t . put_line ( ”MONTHS_BE TWEEN" (dl , d2 ) ) ; 

END; 


Message 


DBMS Output 


01 -JAN -02 
01 / 11/2000 

date courante: 04-MAR-15 
zone horaie: -00:00 
MONDAY 23-02-2015 
01 -MARCH 
5 


4. Maniguler des chaines de caracteres 


Definition 

ASCII (caractere) 

Retourne code ASCII du caractere passe en parametre. 

CHR(entier) 

Inverse de ascii () . 

COMPOSE (chaine) 

Le parametre chaine doit etre comme ceci : 
caractere | | caractere Unicode 
Retourne une chaine formee de la composition entre le 
caractere et le caractere Unicode. 

Liste des caracteres speciaux : 
unistr('\0300') : ' 
unistrf\0301 ') : ' 
unistr('\0302’) : a 
unistr('\0303') : - 
unistr('\0308') : " 

CONCAT (chi , ch2 ) 

Le meme effet que I’operateur | | 

INITCAP (chaine) 

Remplace le l ier caractere de chaque mot de la chaine par 
une majuscule, et les autres par des minuscules. 

INSTR(chl ,ch2) 

Retourne la T® re occurrence de ch2 dans chi. 

LOWER ( chaine ) 

Transforme toute la chaine en minuscules. 

UPPER (chaine) 

Transforme toute la chaine en majuscules. 

LENGTH (chaine) 

Retourne la longueur de la chaine de caracteres. 

LPAD (ch,n,car) 

Rempli la chaine depuis la gauche par le caractere car, 
jusqu'a atteindre le nombre total de caracteres n. 

RPAD (ch , n , car) 

Rempli la chaine depuis la droite par le caractere car, 
jusqu'a atteindre le nombre total de caracteres n. 

LTRIM ( chaine ) 

Enleve les espaces a gauche de la chaine. 

LTRIM ( chaine , ch ) 

Enleve toutes les occurrences de la chaine ch a gauche de 
la chaine. 

RTRIM (chaine) 

Enleve les espaces a droite de la chaine. 

RTRIM ( chaine , ch ) 

Enleve toutes les occurrences de la chaine ch a droite de la 
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chaine. 

TRIM ( [ LEADING | 
TRAILING | BOTH ] 
chl FROM ch2) 

Enleve chl de la chaine ch2 selon I'option choisie entre 

LEADING, TRAILING OU BOTH 

SUBSTR (chaine, p, 1) 

Retourne la sous-chaine qui commence a la position p, et 
qui compte L caracteres. 

Si aucune longueur n’est specifiee, la fonction retourne tout 
le reste de la chaine a partir de la position p. 

REPLACE (chl , ch2 , ch3) 

Remplace la sous-chaine ch2 (2'® me parametre) dans chl, 
par la chaine de remplacement ch3 (3'® me parametre). 

Si aucune chaine de remplacement n’est specifiee, la sous- 
chaine ch2 est remplacee par un vide. 

Exemple 1 


BEGIN 


dbms 

dbms 

dbms 

dbms 

dbms 

dbms 

dbms 

dbms 

dbms 

dbms 

dbms 

dbms 


output . put_ 
output . put_ 
output . put 
output . put 
output . put 
output . put 
output . put 
output . put 
output . put_ 
output . put_ 
output . put_ 
output . put 


line 

line 

line 

line 

line 

line 

line 

line 

line 

line 

line 

line 


(’’ASCII 
( ”CHR” ( 

( ”CHR” ( 

( ”CHR” ( 

( ”CHR” ( 
("COMPOSE” ( 
( ” INITCAP" ( 


('A')) 

65')) 

6 ’)); 

5 • ) ) ; 
2 ')); 
o 


Remarque : produire I’effet des 
lignes 3, 4 et 5 sur Word (utiliser 
le raccourci ALT) 


| | unistr ( 1 \0308 ' ) ) ) ; 
BONJOUR tout le monde ')); 
("INSTR" ( 'bon jour tout le monde', 'ou' 
("UPPER" ( 'BONJOUR tout le monde')); 
("LENGTH" ( 'BONJOUR tout le monde')); 
("LPAD" ('test' , 6, '*')); 

("RPAD" ('test' , 6, '*')); 


)) 


END; 


Message 


DBMS Output 


65 

A 



6 

Bonj our Tout Le Monde 
5 

BONJOURTOUT LE MONDE 
21 

**test 

test** 


Exemple 2 


BEGIN 

dbms_output .put_line ( "LTRIM" ( ' test' ) ) ; 
dbms_output . put_line ( "LTRIM" ( ' 0000 test ' , ' 0 ' ) ) ; 

dbms_output . put_line ( "REPLACE" ( ' OOOOtest ' , ' 0 ' ) ) ; 

dbms_output . put_line ( "REPLACE" ( ' OOOOtest ' , 'O', '*')); 

dbms_output.put_line ("REPLACE" ( ' 1212test ' , ' 12 ' , ' 123 ' ) ) ; 

dbms_output . put_line ( " SUBSTR" ( ' Ceci_es t_un_tes t ' , 2 , 8 ) ) ; 
dbms_output.put_line ("SUBSTR" ( ' Ceci_est_un_test ' , 3) ) ; 
dbms_output.put_line ("TRIM" ( ' ***bonjour_* ')); 
dbms_output .put_line ("TRIM" ( ' * ' FROM ' ***bonjour_* ' ) ) ; 
dbms_output.put_line ("TRIM" ( ' * ' FROM ' ***bonjour_* ')); 
dbms_output.put_line ("TRIM" (LEADING '*' FROM ' ***bonjour_* ' ) ) ; 
dbms_output.put_line ("TRIM" (TRAILING '*' FROM ' ***bonjour_* ' ) ) ; 
dbms_output.put_line ("TRIM" (BOTH '*' FROM ' ***bonjour_* ' ) ) ; 
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END; 


Message DBMS Output 


test 

test 

test 

*test 

123123test 

eci_est_ 

ci_est_un_test 

***bonjour_* 

^**bonjour_ 

bonjour_ 

bonjour_* 

***bonjour_ 

bonjour_ 


Exemple 3 


Declarer & initialiser 3 chaines de caracteres, et afficher la longueur de la chaine la plus 
longue et celle de la chaine la plus courte. 


DECLARE 

dl 

VARCHAR2 (50) ; 

d2 

VARCHAR2 (50) ; 

d3 

VARCHAR2 (50) ; 

BEGIN 

dl 

:= ' 01- JAN-2001 ' ; 

d2 

: = ' abed ' ; 

d3 

:= "CONCAT" (dl, d 


dbms_output.put_line ("GREATEST" ("LENGTH" (dl) , "LENGTH" (d2) , 
"LENGTH" (d3) ) ) ; 

dbms_output.put_line ("LEAST" ("LENGTH" (dl) , "LENGTH" (d2) , 
"LENGTH" (d3) ) ) ; 

END; 


Message DBMS Output 


15 

4 
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5. Afficher des dormees a jecran 


Definition : put line 


Comme on a vu dans les exemples precedents, cette procedure (aucune valeurde 
retour ) predefinie en PL/SQL dans le paquetage dbms_output permet d' afficher une 
ligne avec le rajout d'un caractere de fin de ligne. 

(Les notions de fonctions, procedures et packages seront revues en detail dans les 
prochains chapitres ) 


Operateur de concatenation des valeurs 


Syntaxe : 


dbms output. put line (val 1 \ \ val 2 \ \ ...) ; 


Les valeurs peuvent etre de type numerique, chaine ou date 


Definition : new line 


Cette procedure permet de provoquer un saut de ligne. 


Syntaxe : 

dbms_output . new_line () ; 


Exemple 


BEGIN 

dbms_output . put_line ( ’ bon j our ’ ) ; 

dbms_output . new_line ( ) ; 

dbms_output .put_line ( ’ tout le monde ’ ) ; 

END ; 


Message 

DBMS Output 


bonjour 
tout le monde 
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